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SYSTEME DE RECOUVREMENT TRANSACTIONNEL. 

L'invention concerne le domaine des echanges transactionnels. Les 
systemes de communications utilisant des modes de transfer* asynchrones sont de plus 
en plus utilises. Les communications fiables sont necessaires dans un grand nombre de 
5 cas. La fiabilite peut etre assure par I'ajout de mecanismes transactionnels au service de 

communication. 

Un service de communication asynchrone comprend un gestionnaire 
et un ou plusieurs canaux de communication. 

Un fournisseur (client du sen/ice) emet les informations en adressant 

10 un canal specifique. Le canal transfere I'information au client en invoquant son interface. 

Le canal agit comme un intermediate entre deux consommateurs en decouplant la 
transmission de I'information d'un cote et de Pautre. II faut pouvoir delivrer les 
informations de maniere fiable tout en maintenant la desynchronisation entre les 
fournisseurs et les consommateurs. 

15 Une transaction doit satisfaire quatre proprietes regroupees sous 

I'acronyme ACID signifiant : Atomicite, Coherence, Isolation et Durability. Ces quatre 
proprietes sont etroitement liees entre elles. Les mecanismes de controle de concurrence 
et de reprise mis en oeuvre par un moteur transactionnel ont pour objectif de les faire 
respecter. 

2 0 L'atomicite garantit que, soit Pensemble des mises a jour d'une 

transaction est effectue, soit aucune de ces mises a jour n'est effectuee. Le non-respect de 
cette propriete peut conduire a faire evoluer I'ensemble des donnees de I'etat coherent 
initial a un etat incoherent. 

Afin de faire respecter cette propriete, toute serie d'action constituant 

2 5 une transaction est marquee par un debut et une fin. Le debut d'une transaction signale 

I'evenement de debut d'une transaction au moteur transactionnel. Deux ordres sont 
prevus pour marquer la fin d'une transaction : "commit" permet a la transaction de 
signaler au moniteur transactionnel que du point isole de la transaction toutes ses 
actions se sont bien passe. "Abort" permet a la transaction de signaler au moniteur 

3 0 transactionnel qu'une ou plusieurs de ses actions ont echoue et que la transaction ne 

souhaite pas etre validee (les donnees modifiees par la transaction doivent etres remis 
dans leur etat precedent). En fonction de I'evenement regu en fin de transaction par le 
moniteur transactionnel et en fonction de la vue globale du systeme qu'il peut avoir 
(interaction entre transactions) le moniteur transactionnel decide ou non de valider la 
3 5 transaction c'est-a-dire de rendre definitives les modifications apportees par celle-ci Dans 
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le cos ou una panne systeme se produit avant la fin d'une transaction, celle-ci 
cons.deree comme abandonee. Un des mecanismes possible afin de respecter ,a 
propnete datomicite consiste a conse.er pour chaque transaction en cours ."image 
precedent^de toute donnee m ise a jou, En cas d'abandon d'une transaction, i, est 
poss,b.e ; defa,e la transaction en a PP ,i quant toutes les images 
transaction. 

La propriete de coherence concerne la coherence semantique d'un 

enable de donnees. Le maintien de ce.le-ci peut etre en partie assure par .es 

mecan.smes assurant le contro.e de contraintes d'integrite et par le maintien de la 

propnete des transactions, isolation est indispensable en environnement multi-taches 

pour garantir que chaque transaction voit un etat coherent de I'ensemble des donnees' 

L .solafon consiste a garantir que si ,a transaction s'execute en parallele avec dWres 

transactor,, (accedant a un ensemb.e commun de donnees,, il existe une execution en 

sene des memes transactions qui produirait les memes changements a .'ensemble des 

donnees accedees P ar,.es,tron S actions, Dans ce cassia propriete*d'iso.ation est verifiee 

pour cet ensemble- de transactions. , La Jurabilite garantit que les,mises a jour d'une 

transact,on ,valid e e ( »so ra ^de{i m itives..La seule action qui .doit, permettre de defaire les 
m.sesaiourd'u^^ 

Cette propr.ete.va de.pain.avec.la -pro P rietewd'atomicite*sti P ulant queues mises a jour 
d une transaction forment>un tout coherent qui, est ,oit abandon dans son ensemb.e, 
so.t vahde durablement, Une methode de realisation en. cas de panne- memoire ou de 
panne d.sque entraTnant la perte d'une partie des informations de la base de donnee 
cons,ste a disposer d'un mecanisme de reprise pour recuperer les informations perdues ' 
L-.nvent.on cherche a ameliorer les dispositifs lies a la durability ■ il 
taut avo.r des systemes de recouvrement legers et fiables 

.'utilisation d'une base de donnee est I'un des moyens pour stacker de 
man.ere fiable (« crash resistant », des donnees, sous le contro.e d'un moniteur 
transacted. Afin de permettre une livraison des donnees en toute circonstance dans 
un mode asynchrone, un service de communication doit memoriser les donnees de 
manure fiab.e entre deux etapes de communication (reception des donnees et 
ransm.ssion des donnees,. Cette memorisation doit, offrir de bonnes-performances pour 
I ecnture des donnees;*' 

Les solutions actuelles utilisent une base de donnees fournissant une 
telle .nterface, par exemple compatible XA ou RO. Les donnees sont journalises dans le 
cadre d'une transaction. | es interfaces RA ou XO sont des exemp.es d'interfaces 
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permettant a un moniteur transactionnel externe de contrdler cles donnees. En cas de 
reprise des donnees, ce type d'interface fournit la correlation entre les references des 
transactions externes et les donnees stockees dans la base de donnees qui sont en 
relation avec ces transactions, permettant ainsi de confirmer ou annuler des 
5 modifications sur ses donnees. 

Les base de donnees proposent ce type d'interface et les 
fonctionnalites associees, mais sont peu performantes pour cette ('utilisation particuliere. 
Elles proposent de nombreuses autres fonctionnalites qui sont inutiles pour le 
recouvrement des donnees. 

10 [.'invention* concerne un canal de communication reliant un ensemble 

d'initiateurs de transactions et de consommateurs, associee a un service de 
journalisation possedant une interface de type XA/RO afin de permettre a un systeme 
transactionnel d'accomplir des operations transactionnelles sur des donnees stockees 
dans ledit service de journalisation. Ces canaux peuvent etre integres a tout systeme 

15 d'echanges transactionnels. 

L'invention concerne egalement un procede de communication entre 
un ensemble d'initiateurs de transactions et de consommateurs, compoiiant des canaux 
de communications intermediates. On memorise chaque operation validee dans un 
service de journalisation possedant une interface de type XA/RO afin de permettre le 

2 0 recouvrement des operations transactionnelles validees. 

L'invention utilise, a la place d'une base de donnees possedant une 
interface transactionnelle et associee a un canal de communication, un systeme de 
journalisation offrant une telle interface. Cette interface permet a un moniteur 
transactionnel traditionnel de repercuter sur les objets journalises la bonne terminaison 
25 de la transaction (« commit ») ou mauvaise (« rollback »), respectivement confirmer les 

changements ou les annuler. 

Un systeme de journalisation stocke toutes les valeurs successives 
d'une variable, en conservant les anciennes. En cas perie de donnees, on pourra 
toujours retrouver une valeur plus ancienne de ces donnees. 

3 0 On ajoute une interface de type XA ou de type RO, permettant a un 

moniteur transactionnel externe de confirmer ou annuler des modifications sur des 
donnees journalisees, ainsi que de recouvrer des donnees. Le service de journalisation 
fournit des moyens de stockage fiables, avec des ecritures rapides. L'interface ajoutee 
permet d'automatiser la terminaison de modifications des donnees suivant les indications 
3 5 fournies par un moniteur transaction externe. 
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(.'invention permet hnteroperabilite avec des moniteurs transaction nels 
externes en cas de probleme. 

Cette couche supplemental dans le service de connexion fournit une 
interface de type XA pour associer les identifiants transactionnels aux actions effectuees 
dans le sen/ice de journalisation 
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Revendication 

1 - Canal de communication reliant un ensemble d'initiateurs de 
transactions et de consommateurs, associee a un sen/ice de journalisation possedant une 
interface de type XA/RO afin de permettre a un systeme transactionnel d'accomplir des 
operations transactionnelles sur des donnees stockees dans ledit service de 
journalisation. 

2 - systeme de communication transactionnel utilisant une pluralite de 
canaux de communication selon la revendication 1 

3 - Procede de communication entre un ensemble d'initiateurs de 
transactions et de consommateurs, comportant des canaux de communications 
intermediaires, caracterise en ce que I'on memorise chaque operation validee dans un 
service de journalisation possedant une interface de type XA/RO afin de permettre le 
recouvrement des operations transactionnelles validees. 
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